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CLAIMS 

WHAT IS CLAIMED IS: 

1. A method of migrating data items, each of said data items being 
associated with an identifier, said method comprising the acts of: 

storing an adjustable throttle value; 

for a first of said data items, computing a first index value based 
on an identifier associated with said first data item; 

determining that the relationship between said first index value 
and said throttle value meets predetermined criteria; and 

2. The method of claim 1, wherein said predetermined criteria comprises 
a determination that said first index value is\ess than said throttle value. 

\ 

3. The method of claim 1, further comprising the acts of: 

for a second of said dat\i items, computing a second index value 
based on an identifier associated with said second data item; 

determining that the relationship between said second index value 
and said throttle value does not meet said predeteWned criteria; and 

leaving said second data i\em in its current location without 
copying said second data item to said data store. 

4. The method of claim 1, wherein each of said data items comprises 
customization information for a web page, each of sztad data items being stored on a 
computing device to which the customization relates, spd method further comprising 
the acts of: 

providing a web page to a first one d£ the computing device based 
at least in part on information copied to said data store. 
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5. The method of claim 4, further comprising the acts of: 
adjusting said throttle value downward; 

determining that said the relationship between said first index 
5 value and the downward-adjustety throttle value does not meet said pre-determined 
criteria; and 

providing a Veb page to one of the computing devices without 
using the information copied to said uata store. 

10 6. The method of claim 1, wherein each of said data items has a flag 

associated therewith, each flag being adapted to assume either a set or an unset state, 
and wherein said method further comprises: 

determining that the^ flag corresponding to said first data item is 

in the unset state. 

15 

7. A computer-readable medidpi having computer-executable instruction 
to perform the method of claim 1 . 



8. A method of converting a web site from client-based storage of 
20 information to central storage of information comprising the acts of: 

selecting a group of users o\ the web site based on an identifier 
associated with each user; 

copying data from each of th^ selected user's client computing 
devices to a central storage location; and 
25 providing a web page to each of the selected group of users based 

on the copied data stored in said central storage location. 
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9. The methocKof claim 8, wherein the act of selecting a group of users 



comprises: 



computing a hash of each user's associated identifier; and 
determining A for each user, whether the hash value meets 



5 predetermined criteria. 



10 



10. The method of dlaim 9, wherein the act of determining whether a 
hash value meets predetermined critqria comprises comparing the hash value to a preset 
value. 

11. The method of clkm 10, wherein the act of comparing the hash 
value to a preset value comprises determining whether the hash value is less than the 
preset value. 



15 12. The method of claim 8A further comprising the act of: 

setting an indication pr each user for whom data has been copied 
to the central storage location. 

13. The method of claim 12, farther comprising the act of: 
20 maintaining, for one ofuhe selected users, a mirror copy of that 

user's centrally-stored data at the user's client computing device. 
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14. The method of claim 8, further comprising the acts of: 
deselecting one of the selected users; 

providing a web page to the\selected user without using the copy 
of the user's data stored at the central storage locati^ 
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15. A method of (deploying a new software feature to a plurality of users, 
said method comprising the acts 6f : 

setting a throttle value to a first proportion; 
selecting a first group of said plurality of users, the number of 
5 users in said first group being in \tbout said first proportion to the number of said 
plurality of users; 

providing said feature to said first group; 

increasing said \throttle value from said first proportion to a 

second proportion; 

10 selecting a second group of said plurality of users, the number of 

users in said second group being in abomt said second proportion to the number of said 
plurality of users, wherein all users in\said first group are included in said second 
group; and 

providing said featuie to said second group. 

16. The method of claim 15,\further comprising the act of: 

reducing said throttle yalue from said second proportion to a third 

proportion; 

selecting a third group \of said plurality of users, the number of 
20 users in said third group as compared with the number of said plurality of users being 
about equal to said third proportion, wherein a\l users in said third group are included 
in said second group; and 

removing said feature froi\i those users who are in said second 
group but not in said third group. 
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17. The method of claim 15, wherein each of said user is associated with 
an identifier, wherein said throttle value is a numW within the range m to w, and 
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wherein said first and second groups of users are selected according to a process 
comprising the steps of: 

converting the identifiers associated with the users to a value in 
the range from m to n\ 

comparing the converted identifiers with the throttle value; and 
selecting a user based on the comparison of the converted 
identifiers with the throttle value. 



18. The method of claim 17, wherein the act of comparing the converted 
10 identifier with the throttle value con\prises determining whether the converted identifier 

is less than the throttle value. 

19. The method of claiira 17, wherein the act of converting the identifiers 
comprises hashing the identifiers using £\hash function. 

15 

20. The method of claim 19, wherein said range is 0 to n-1, and wherein 
said hash function comprises a modulo n hash function. 

21. The method of claim 15, wherein said feature comprises a change in 
20 the location of specified data, and wherein the acts of providing the feature comprise 

copying data from one location to another location. 



22. The method of claim 15, further comprising the act of: 

delaying the determination oV whether a given user falls into said 
25 first or second group until a contact is initiated by tne given user. 



23. The method of claim 15, wherein each of said plurality of users is a 
user of a web site that stores customization information for each of the users and 
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provides a customized version of the web site to each user based on the stored 
customization information, wherein said feature comprises migrating the customize 
data for a user from a client-si\e file to a common data store located remotely from 



each user, wherein the act of providing said feature to said first group comprises: 

copying, from the client-side file to the common data store, the 
customization data for each user in\the first group; 

and wherein the act of providing said feature to said second group comprises: 

copying, froiA the client-side file to the customization store, the 
customization data for each user in \* second group for whom the data has not already 
been copied. 



indication for each user whose data has been migrated 
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24. The method of clairft 23, further comprising the acts of: 
setting an 

to the common data store; and 

maintaining, in \ client-side file, a mirror copy of the 

customization data for each user for whoA the indication has been set. 

25. A computer-readabll medium having computer-executable 
instructions to perform the" method of claim 15. 

26. A system for providing a web site comprising: 

a first computing device Wch provides a web page to a plurality 
of second computing devices, each of s\ second computing devices being 
communicatively connected to said first computing device, said first computing dev.ce 
providing a customized version of said web pag\ to each of said second computmg 
devices based on customization information associated with each of said second 
computing devices, each of said second computing devices storing its respecUve 
customization information; 
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a data Astore which stores corresponding customization 
information for at least some of said second computing devices; 

a throttle module which selects certain ones of said second 
computing devices for storage of tMeir respective customization information in said data 
store; and 

a migration m&dule which copies the customization information 
from the selected ones of said second computing devices to said data store. 



27. The system of claim 26, further comprising: 

10 a customization nLdule which customizes the web page for each 

\ 

of the second computing devices, wherein the customization is based on information 
stored in the data store for the selected! ones of the second computing devices, and 
wherein the customization is based on information stored at the respective second 
computing devices for the non-selected ones of the second computing devices. 

15 

28. The system of claim 26 \ wherein each of said second computing 
devices is associated with an identifier, and wnerein said system further comprises: 

a hashing module whiclj| hashes the identifier for each of said 
second computing devices, 

20 wherein said throttle module receives a value from said hashing module and selects 

\ 

certain ones of said second computing devices based on the received value. 

■\ 

29. The system of claim 26, wherein each of said second computing 
devices is associated with an identifier, and wherein said system further comprises: 

25 a throttle value storage location;^ 

wherein said throttle module selects certain ones of Isaid second computing devices 
based on the value stored at the throttle value storage lo&ation and further based on the 
identifiers associated with the respective second computing, devices. 
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30. The system \of claim 26, wherein said throttle module selects said 
certain ones of said second computing devices in a predetermined proportion to the total 
number of second computing devices. 

5 I 

31. A system for migrating web site data comprising: 

means for storing an operator-adjustable value; 
means for selecting a group of users of said web site based on an 
identifier associated with each of said users and further based on said operator- 
10 adjustable value; \ 

means for transferring data from the selected users' computing 
devices to a data store; \ 

means for adjusting said operator-adjustable value downward; 
means for de-seleqting at least some of the selected users in 
15 response to the downward adjustment of said user-adjustable value; and 

means for rendering\a web page based at least in part on data 
stored on the de-selected users' computing qe vices. 

32. The system of claim 31, further comprising: 

20 means for indicating thft validity of the data store copy of said 

users' data including a flag stored on each of saVd users' computing devices; 

means for invalidating theViata store data for the de-selected users 
using said flag. \ 



